package org.dromara.datacheck.service.jst;

import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.datacheck.domain.bo.JstAndJDTableDataEntryBo;
import org.dromara.datacheck.domain.bo.jst.JstOtherOutEnterWarehouseOrderBo;
import org.dromara.datacheck.domain.jst.JstOtherOutEnterWarehouseOrder;
import org.dromara.datacheck.domain.vo.jst.JstOtherOutEnterWarehouseOrderVo;

import java.util.Collection;
import java.util.List;
import java.util.Map;

/**
 * 聚水潭-其他出入库单Service接口
 *
 * @author 刘武贵
 * @date 2024-09-08
 */
public interface IJstOtherOutEnterWarehouseOrderService {

    /**
     * 查询聚水潭-其他出入库单
     *
     * @param id 主键
     * @return 聚水潭-其他出入库单
     */
    JstOtherOutEnterWarehouseOrderVo queryById(Long id);

    /**
     * 分页查询聚水潭-其他出入库单列表
     *
     * @param bo        查询条件
     * @param pageQuery 分页参数
     * @return 聚水潭-其他出入库单分页列表
     */
    TableDataInfo<JstOtherOutEnterWarehouseOrderVo> queryPageList(JstOtherOutEnterWarehouseOrderBo bo, PageQuery pageQuery);

    /**
     * 查询符合条件的聚水潭-其他出入库单列表
     *
     * @param bo 查询条件
     * @return 聚水潭-其他出入库单列表
     */
    List<JstOtherOutEnterWarehouseOrderVo> queryList(JstOtherOutEnterWarehouseOrderBo bo);

    /**
     * 新增聚水潭-其他出入库单
     *
     * @param bo 聚水潭-其他出入库单
     * @return 是否新增成功
     */
    Boolean insertByBo(JstOtherOutEnterWarehouseOrderBo bo);

    /**
     * 修改聚水潭-其他出入库单
     *
     * @param bo 聚水潭-其他出入库单
     * @return 是否修改成功
     */
    Boolean updateByBo(JstOtherOutEnterWarehouseOrderBo bo);

    /**
     * 校验并批量删除聚水潭-其他出入库单信息
     *
     * @param ids     待删除的主键集合
     * @param isValid 是否进行有效性校验
     * @return 是否删除成功
     */
    Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);

    /**
     * 查询聚水潭-其他出入库单列表所有数据
     *
     * @return 聚水潭-其他出入库单列表
     */
    List<JstOtherOutEnterWarehouseOrder> queryAll();

    /**
     * 清空聚水潭-其他出入库单列表所有数据
     *
     * @return 聚水潭-其他出入库单列表
     */
    Integer deleteAll();

    /**
     * 查询聚水潭-其他出入库单列表
     * 场景分类：其他出库-报废，盘亏
     * 业务查询条件：根据out_warehouse_type出库类型为报废，盘亏查询
     */
    TableDataInfo<JstOtherOutEnterWarehouseOrderVo> queryPageListByOutWareHouseType1(JstOtherOutEnterWarehouseOrderBo bo, PageQuery pageQuery);

    /**
     * 查询聚水潭-其他出入库单列表
     * 场景分类：其他出库-供应商赔付，盘盈，领用退回
     * 业务查询条件：根据out_warehouse_type出库类型为供应商赔付，盘盈，领用退回查询
     */
    TableDataInfo<JstOtherOutEnterWarehouseOrderVo> queryPageListByOutWareHouseType2(JstOtherOutEnterWarehouseOrderBo bo, PageQuery pageQuery);

    /**
     * 查询聚水潭-其他出入库单列表
     * 场景分类：调拨-销退仓,次品仓调拨委外加工仓
     * 业务查询条件：根据out_warehouse_type出库类型为仓库编码+仓库的单子查询
     */
    TableDataInfo<JstOtherOutEnterWarehouseOrderVo> queryPageListByOutWareHouseType3(JstOtherOutEnterWarehouseOrderBo bo, PageQuery pageQuery);

    /**
     * 查询聚水潭-其他出入库单列表
     * 按日期汇总的统计数据
     */
    TableDataInfo<Map<String, Object>> jstAndJdSum();

    /**
     * 查询聚水潭-其他出库单列表以及金蝶-其他出库单数据汇总（按日期汇总）
     * 场景分类：6、其他出库-报废，盘亏
     */
    TableDataInfo<JstAndJDTableDataEntryBo> jstAndJdSumByDateByScrapInventory();

    /**
     * 查询聚水潭-其他出库单列表以及金蝶-其他出库单数据汇总（按日期汇总）
     * 场景分类：7、其他入库-供应商赔付，盘盈，领用退回
     */
    TableDataInfo<JstAndJDTableDataEntryBo> jstAndJdSumByDateByClaimOrderProfitReturn();

    /**
     * 查询聚水潭-其他出库单列表以及金蝶-直接调拨单数据汇总（按日期汇总）
     * 场景分类：8、调拨-销退仓,次品仓调拨委外加工仓
     */
    TableDataInfo<JstAndJDTableDataEntryBo> jstAndJdSumByDateBySaleReturnTransfer();

    /**
     * 查询聚水潭-其他出入库单列表（金蝶缺少的数据）
     * 场景分类：6、其他出库-报废，盘亏
     */
    TableDataInfo<JstOtherOutEnterWarehouseOrderVo> queryPageListByScrapInventoryByJdDeficiency(JstOtherOutEnterWarehouseOrderBo bo, PageQuery pageQuery);

    /**
     * 导出聚水潭-其他出入库单列表（导出6、其他出库-报废，盘亏的差异数据）
     */
    List<JstOtherOutEnterWarehouseOrderVo> queryListScrapInventoryByJdDeficiency(JstOtherOutEnterWarehouseOrderBo bo);

    /**
     * 查询聚水潭-其他出入库单列表（金蝶缺少的数据）
     * 场景分类：7、其他入库-供应商赔付，盘盈，领用退回
     */
    TableDataInfo<JstOtherOutEnterWarehouseOrderVo> queryPageListByClaimOrderProfitReturnByJdDeficiency(JstOtherOutEnterWarehouseOrderBo bo, PageQuery pageQuery);

    /**
     * 导出聚水潭-其他出入库单列表（导出7、其他入库-供应商赔付，盘盈，领用退回 的差异数据） TODO 待对接
     */
    List<JstOtherOutEnterWarehouseOrderVo> queryListClaimOrderProfitReturnByJdDeficiency(JstOtherOutEnterWarehouseOrderBo bo);

    /**
     * 查询聚水潭-其他出入库单列表（金蝶缺少的数据）
     * 场景分类：8、调拨-销退仓,次品仓调拨委外加工仓
     */
    TableDataInfo<JstOtherOutEnterWarehouseOrderVo> queryPageListBySaleReturnTransferByJdDeficiency(JstOtherOutEnterWarehouseOrderBo bo, PageQuery pageQuery);

    /**
     * 导出聚水潭-其他出入库单列表（导出8、调拨-销退仓,次品仓调拨委外加工仓的差异数据）
     */
    List<JstOtherOutEnterWarehouseOrderVo> queryListSaleReturnTransferByJdDeficiency(JstOtherOutEnterWarehouseOrderBo bo);
}
